<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>外间距测试</title>
    <style>
        body{
            /* 可以去掉body默认四个方向的8px外间距 */
            margin: 0;
        }
        .fu{
            background-color: rgba(255,255,0,.3);/*透明度.3 0透明 1不透明*/
            /* 给父元素设置BFC结界 把首尾元素超出的外间距包裹在内*/
            overflow: hidden;
        }
        .fu>div{
            width: 100px;
            height: 100px;
            background-color: rgba(0,0,255,.6);
            border: 2px solid #00f;
            color: #fff;
        }
        /* 相邻兄弟垂直方向外间距取最大值显示,不会相互叠加*/
        .z1{
            margin-bottom: 30px;
            margin-top: 50px;/* 第一个子元素的上外间距会超出父元素的范围*/
        }
        .z2{
            margin-top: 50px;
        }
        .z4{
            margin-bottom: 50px;/* 最后一个子元素的下外间距会超出父元素的范围*/
        }
        .z3{
            margin: 10px 20px 30px 40px;
            margin: 10px;
            margin: 10px 20px;
            margin: 10px 20px 30px;
            /* 上下0 左右auto让浏览器自动计算为相等的值 实现块级元素的水平居中*/
            margin: 0 auto;
        }
        span{
            border: 2px solid #f00;
        }
        .s2{
            /* 行内元素垂直方向的外间距不生效,不要使用*/
            margin: 30px 20px;
        }
    </style>

</head>
<body>
<span>span1</span>
<span class="s2">span2</span>
<span>span3</span>
<div class="fu">
    <div class="z1">子元素</div>
    <div class="z2">子元素</div>
    <div class="z3">子元素</div>
    <div class="z4">子元素</div>
</div>

</body>
</html>